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METHOD FOR MINIMIZING FEEDBACK 
RESPONSES IN ARQ PROTOCOLS 

CROSS-REFERENCES TO RELATED APPLICATIONS 
5 This Application for Patent claims the benefit of priority from, and hereby 

incorporates by reference the entire disclosure of, co-pending U.S. Provisional 
Application for Patent Serial No. 60/128,517, filed April 9, 1999, 

BACKGROUND OF THE INVENTION 

Technical Field of the Invention 
1 0 The present invention relates in general to the telecommunications field and, 

in particular, to a method for minimizing feedback responses in Automatic Repeat 
Request (ARQ) protocols, such as, for example, selective-repeat ARQ protocols. 

Description of Related Art 

When data is conveyed between nodes in a telecommunication network, certain 
1 5 algorithms are used to recover from the transmission of erroneous data and the loss of 
data on the transmission links between the nodes. An algorithm commonly used to* 
recover from the transmission of erroneous data is referred to as an ARQ protocol. 

The existing ARQ protocols (Le., algorithms) include two peer entities that 
communicate with each other over transmission links. Each such entity includes a 
20 receiver and a sender. The units of data conveyed between the peer entities are 
commonly referred to as Protocol Data Units (PDUs). The ARQ protocols include 
certain rules for sending and receiving PDUs, as well as rules for the structure of the 
PDUs. As such, the name "Automatic Repeat Request" indicates the basic function 
of the protocol: the receiver requests the sender to retransmit those PDUs that were 

2 5 lost or contained errors during transmission. 

The receiver can inform the sender about which PDUs were correctly received 
(i.e., receiver acknowledges correctly-received PDUs) and/or which PDUs were 
incorrectly received. When the sender receives this information, it retransmits the 
"lost" PDUs. In other words, an ARQ protocol is a set of rules that allow the use of 

3 0 efficient retransmission mechanisms between a sending side and receiving side in a 
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communication system. These rules specify, for example, how and in what form the 
PDUs are to be constructed so that the receiving side can interpret the conveyed PDUs 
correctly and respond to them accordingly. 

Three main types of information elements (PDUs) can be transferred between 
5 two ARQ peer entities: user data; error recovery control data; and common control 
data. These three types of PDUs can be found in all of the existing ARQ protocols. 
A user data PDU contains at least user data and a sequence number. An error recovery 
control data PDU contains various control information needed for error recovery and 
control functions such as positive and negative acknowledgments. A common control 

1 0 data PDU contains common control data. 

In the known High Level Data Link Control (HDLC) protocol, which forms 
the basis for many existing ARQ protocols, the three types of PDUs are called, 
respectively, information frames (I-frames), supervisory frames (S-frames), and 
unnumbered frames (U-frames). Examples of HDLC-derived ARQ protocols are the 

1 5 Radio Link Protocol (RLP) used in the Global System for Mobile Communications 
(GSM), the Radio Link Control (RLC) and Logical Link Control (LLC) protocols used 
in the General Packet Radio Service (GPRS), the Infrared Link Access Protocol 
(IrLAP) used in IrDA systems, and the LAP-B protocol used in X.25 systems. 
Notably, PDUs that include user data and at least a sequence number are denoted 

2 0 herein as Data-PDUs (D-PDUs), and PDUs that include control data needed for error 
control/recovery are denoted herein as Status-PDUs (S-PDUs). 

In most communication systems, user data information is conveyed in both 
directions between the peer entities. A common feature included in an ARQ protocol 
is the possibility of including error control information in the user data PDUs. This 

2 5 capability is known as "piggybacking". For example, an acknowledgment is included 

in all I-frames (i.e., D-PDUs) of HDLC-derived protocols. The acknowledgment 
informs the peer entity about the sequence number of the last (in-sequence) correctly 
received PDU. 

The most common existing ARQ protocols implement one or more 

3 0 mechanisms to recover from errors on a transmission link, such as a Stop-and-Wait 

ARQ, Go-back-N ARQ, and Selective-Repeat ARQ. The use of these mechanisms 
and ARQs in general is well known. 
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FIGURE 1 is a sequence diagram that illustrates the use of ARQ protocols. As 
shown, two ARQ peer entities 10, 12 are communicating with each other. The arrows 
in FIGURE 1 indicate the transmission of PDUs between the two entities, and the 
content of each PDU is described directly above the respective arrow. Referring to 
5 FIGURE 1, a sequence of transmitted D-PDUs and S-PDUs is shown. A D-PDU 
includes user data, a sequence number (SN), and possibly piggybacked error control 
information. An S-PDU includes status information but no user information. A 
sequence number (SN=x) is associated with a D-PDU to identify that specific D-PDU. 
An acknowledgment (ACK=x) is used to acknowledge any PDU with a SN<x. A 

10 negative acknowledgment (NAK=x) is used to acknowledge .that a PDU (with an 
SN=x) has not been correctly received. 

Two types of error control feedback responses are shown in FIGURE 1 . For 
one of the feedback responses (e.g., S-PDU, ACK=2) 14, the second ARQ peer entity 
12 has acknowledged that it has received the PDUs with the SN=0 and SN=1 . For the 

15 second type of feedback response (e.g., S-PDU, NAK=3) 16, the second peer entity 
12 has indicated that the PDU with the SN=3 was corrupted and should be 
retransmitted by the first peer entity 10. 

As discussed above, the S-PDUs are special PDUs which are transmitted 
between peer entities. An S-PDU includes information about the SNs of corrupted 

20 PDUs. TwomainmethodsarecurrentlyusedforcodingtheSNswithinS-PDUs. One 
such method is to use a list of SNs to be retransmitted. The second method is to use 
a bitmap to represent the SNs to be retransmitted. As such, apart from representing 
SNs, an S-PDU also includes a format identifier which can be used by a receiver to 
distinguish between the different PDU formats (i.e., D-PDUs and S-PDUs). 

2 5 The list method used for coding SNs includes the SNs of the erroneous PDUs 

in the S-PDU. If the length of the list is not predefined and thereby known, this length 
information is indicated in the S-PDU. For example, a length field can be included in 
the S-PDU. FIGURE 2 shows such an S-PDU, which can be created by a receiver 
using a list method for coding SNs. 

30 Referring to FIGURE 2, a receiver can create an S-PDU with the contents 

shown, if the sender has transmitted a sequence of D-PDUs with SNs=0-15, and the 
PDUs with SNs=3 ,5,6,7 and 8 have failed (not been correctly received). For example, 
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the first two elements in the list (after the length field) indicate that the D-PDU with 
SN=3 was erroneous. The third and fourth elements in the list indicate that the D- 
PDUs with SNs=5-8 were erroneous. The final element is included to acknowledge 
the remaining PDUs (SNs up to 15). 
5 The size of the S-PDU depends on the number of bits used to represent the 

PDU format identifier field, the length field and the SN field As such, the size of an 



PDU. SIZE^^size (pdu . forma t . field) +size { length . field) 

+no. listelements+8ize{seq. no . field) . ^ 

S-PDU can be calculated by the expression: 

For example, this list method is used in the SSCOP protocol, wherein two S-PDU 
formats exist and are denoted by the term "STAT" for a variable list length, and 

10 "USTAT" for a list with a limited number of elements (e.g., 2 elements). 

FIGURE 3 shows an S-PDU which can be created by a receiver using a bitmap 
method for coding SNs. When a bitmap is used to indicate SNs, the receiver creates 
the S-PDU from the SN of the last in-sequence correctly received D-PDU and a 
bitmap. This SN is referred to as a Start SN (SSN). Consequently, this S-PDU 

15 implicitly acknowledges all D-PDUs received up to the value of the SSN. Each 
location in the bitmap is used to address a specific S-PDU relative to the SSN. 
Typically, the size of the bitmap is fixed to the size of the ARQ receiver window and 
does not have to be explicitly indicated. If the bitmap is not fixed, the length has to 
be indicated. 

2 0 The bitmap shown in FIGURE 3 shows an S-PDU created from the example 

described above with respect to FIGURE 2, and a window size of 16. As such, each 
location in the bitmap can have one of the two values, 0 or 1: A "1" means that 
SN=(SSN+bit_position) has been correctly received; and a "0" value means that 
SN=(SSN+bit_position) has not been correctly received. Of course, the meaning of 

25 the "0" and M 1 M values can be interchanged. The size of an S-PDU when using such 
a bitmap can be derived from the following expression: 
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PDU. SIZE BI7KAP =size (pdu . format, field) +size(SSN. field) 

+aize(bitmap. field) . <2) 



Both the RLC and LLC protocols in the GPRS system use such an expression and 
convey bitmaps between peer entities for error control purposes. 

A significant problem with existing ARQ protocols is that they are static in 
construction (e.g., fixed leiigth messages are used). In certain situations, this approach 
5 leads to a waste of bandwidth resources, because a great deal of overhead information 
is transmitted unnecessarily. For example, such situations can occur in systems having 
a large number of D-PDUs being transmitted between two ARQ peer entities, and 
these D-PDUs have to be acknowledged and selectively requested for retransmission. 
For some error control situations, the existing solutions introduce a significant amount 

10 of unnecessary overhead. The following example illustrates such a situation. 

In the Wideband-Code DivisionMultiple Access (WCDMA) system currently 
being standardized for the so-called 3rd Generation Cellular Communication System, 
one ARQ protocol used is an RLC protocol. The SN set includes the values 0-4095, 
which means that each SN is coded with 1 2 bits. An assumption can be made that for 

15 high data rates, a relatively large set of SNs will have to be addressed in some S- 
PDUs. Also, assume that the status of 100 D-PDUs (SN=1-100) needs to be 
communicated between the RLC peer entities in an S-PDU. 

Table 1 below shows the number of bits needed to code an S-PDU using the 
list and bitmap methods described above. Different error circumstances are provided 

20 to highlight the large difference in the number of bits required for the two methods. 
Assume that the following element sizes are used: bitmap=l 28 bits; length=5 bits; and 
one PDU format identifier = 1 bit (for distinguishing between a D-PDU and an S- 
PDU). As such, the different S-PDU sizes shown in Table 1 are calculated in 
accordance with Equations (1) and (2) above, respectively. As illustrated by rows 2-5 

25 in Table 1 , both of the existing solutions have problems with efficiently building small 
S-PDUs for the error circumstances shown. The length of the LIST does not depend 
so much on the number of erroneous D-PDUs, but rather on the distribution of the 
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errors within the window used. This fact becomes evident by comparing rows 1 and 
2 in Table 1. 





Erroneous D-PDUs 
(SN) 




SizeofS-PDU 
(bits) 






#SN 


LIST 


BITMAP 


1 


51-77 


27 


42 


141 


2 


1. 25. 50. 95 


4 


114 


141 


3 


27-30. 35. 39. 41. 91-93 


10 


138 


141 


4 


3,7.11,16,33,45, 55,66,78,82, 


11 


282 


141 


5 


10-9.9 31.33.36 


23 


114 


141 



Table 1 



A general statement of the problem to be solved is to determine how to 
efficiently represent (encode) in a message the status of an arbitrary amount and 
distribution of n numbers from a set of m numbers. As such, a significant need exists 
for a method that can be used to minimize the size of S-PDUs in an ARQ protocol. 
Also, a significant need exists for a method that can be used to maximize the number 
of SNs in an S-PDU with limited size, if it is not possible to fit all potential SNs into 
a single S-PDU. As described in detail below, the present invention successfully 
resolves the above-described problems and other related problems. 



SUMMARY OF THE INVENTION 

In accordance with an embodiment of the present invention, a method for 
minimizing feedback responses in an ARQ protocol is provided, whereby different 
mechanisms can be used to indicate erroneous D-PDUs and construct S-PDUs. In 
particular, these different mechanisms can be combined in a single S-PDU. The S- 
PDUs are constructed so as to optimize system performance in accordance with certain 
criteria. One such criterion used is to minimize the size of the S-PDUs. A second 
such criterion used is to maximize the number of SNs included in an S-PDU of limited 
size. 
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An important technical advantage of the present invention is that radio 
interface bandwidth resources can be saved. 

Another important technical advantage of the present invention is that protocol 
overhead can be minimized. 
5 Still another important technical advantage of the present invention is that 

system capacity can be increased. 

Yet another important technical advantage of the present invention is that the 
number of feedback responses in a selective-repeat ARQ protocol can be minimized. 



BRIEF DESCRIPTION OF THE DRAWINGS 
10 A more complete understanding of the method and apparatus of the present 

invention may be had by reference to the following detailed description when taken 
in conjunction with the accompanying drawings wherein: 

FIGURE 1 is a sequence diagram that illustrates the use of ARQ protocols; 

FIGURE 2 is a diagram that shows an S-PDU which can be created by a 
15 receiver using an existing list method for coding SNs; 

FIGURE 3 is a diagram that shows an S-PDU which can be created by a 
receiver using an existing bitmap method for coding SNs; 

FIGURE 4 is abitmap message for use in an S-PDU, constructed in accordance 
with a first embodiment of the present invention; 

2 o FIGURE 5 is a diagram of a message with the fields and contents of the LIST 

S-PDU for row 2 in Table 1, constructed in accordance with the first embodiment of 
the present invention; 

FIGURE 6 is a diagram of the fields of a LIST' message in an S-PDU, 
constructed in accordance with the first embodiment of the present invention; 
25 FIGURE 7 is a diagram that shows the contents of an "ACK" message 

constructed in accordance with the second embodiment of the present invention; 

FIGURE 8 is a diagram that illustrates how an S-PDU can be constructed in 
accordance with the combination method of the second embodiment; 

FIGURE 9 is a diagram that shows the contents of row 1 of Table 1 in a 

3 o combination S-PDU, constructed in accordance with the second embodiment of the 

present invention; 
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FIGURE 10 is a diagram that shows the contents of row 2 of Table 1 in a 
combination S-PDU, constructed in accordance with the second embodiment of the 
present invention; 

FIGURE 1 1 is a diagram that shows the contents of row 3 of Table 1 in a 
5 combination S-PDU, constructed in accordance with the second embodiment of the 
present invention; 

FIGURE 12 is a diagram that shows the contents of row 4 of Table 1 in a 
combination S-PDU, constructed in accordance with the second embodiment of the 
present invention; and 

10 FIGURE 13 is a diagram that shows the contents of row 5 of Table 1 in a 

combination S-PDU, constructed in accordance with die second embodiment of the 
present invention. 



DETAILED DESCRIPTION OF THE DRAWINGS 

The embodiments of the present invention and their advantages are best 
15 understood by referring to FIGURES 1-13 of the drawings, like numerals being used 

for like and corresponding parts of the various drawings. 

Essentially, in accordance with a first embodiment of the present invention, a 

method for minimizing feedback responses in an ARQ protocol is provided, whereby 

different mechanisms can be used to indicate erroneous D-PDUs and construct S- 
2 0 PDUs, The S-PDUs are constructed so as to optimize performance in accordance with 

certain criteria. One such criterion used is to minimize the size of the S-PDUs, A 

second such criterion used is to maximize the number of SNs included in an S-PDU 

of limited size. 

Specifically, hereinafter, the basic components being described are messages. 

2 5 For this embodiment, such a message can be described by using a Type, Length, Value 

(TLV) syntax. In other words, each message includes three fields. One field includes 
type information, the second field includes length information, and the third field 
includes a value. The size of the type field is preferably non-zero, while the sizes of 
the other two fields can be zero. 

3 o Notably, as mentioned earlier, all existingbitmap solutions include information 

about the sequence number (herein called the SSN) of the last received in-sequence 
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D-PDU in a constructed S-PDU. The SSN indicates that no errors exist prior to that 
sequence number. In other words, the SSN is used to acknowledge all D-PDUs having 
SNs.up to that of the SSN. 

For this exemplary embodiment, a basic message to be used for minimizing 
5 feedback responses in an ARQ protocol can be constructed as follows. Using a 
BITMAP method for this embodiment, the SN included in a constructed S-PDU 
indicates the SN of any (not necessarily the first) erroneous D-PDU from the set of 
SNs. The status of the subsequent SNs are indicated in the bitmap. Although the SN 
of the first erroneous D-PDU is used in this exemplary embodiment, it should be 

10 understood that any D-PDU (from the SN set) can be used in the bitmap method 
instead. In that case, the bitmap also has to include the status (0 or 1) of the SN 
included in the constructed S-PDU. As such, a "BITMAP" message can be created 
with a type identifier field, a first SN (FSN) field, a bitmap length field, and a bitmap 
field. FIGURE 4 illustrates a bitmap message with such fields for use in an S-PDU, 

15 in accordance with the first embodiment of the present invention. 

Referring to the bitmap message shown in FIGURE 4, a number of methods 
can be used to represent the length of the bitmap (LENGTH field). For one method, 
a predefined number of bits can be used to represent the size of the bitmap in a basic 
data unit. Such a data unit can have any granularity and include, for example, one or 

2 0 more bits, bytes, words, etc. For example, if a byte is used as the basic data unit, the 
value, x, in the LENGTH field means that 8*x SNs are covered by the bitmap. This 
resulting value also represents the size of the bitmap in bits. 

For a second method used to represent the length of the bitmap, a different SN 
can be used to indicate the last SN covered by the bitmap. The size of the LENGTH 

2 5 field is then equal to the size of the FSN field. As such, the size of the bitmap can be 

calculated by subtracting the FSN value from the LENGTH value. 

A third method that can be used for representing the length of the bitmap is to 
fix the size of the bitmap so that no LENGTH field is required in the S-PDU. 
Alternatively, the size of the LENGTH field can be set to zero. Also, the size of the 

3 0 FSN field can also be set to zero if the SN that the bitmap covers is signalled remotely. 

Such a method is described in more detail below. 
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Notably, a conventional data compression method can be used to compress the 
information in the bitmap field. As such, both normal and compressed bitmaps can 
be included in one S-PDU. In this case, the value of the type field for the compressed 
bitmap would be different than that for a normal bitmap. 
5 As mentioned earlier, a significant drawback of the existing LIST methods is 

that two SNs are required for each error group. An error group comprises a single 
error or several consecutive errors of D-PDUs. In order to resolve such a problem 
using a LIST method in accordance with this exemplary embodiment, only erroneous 
SNs are listed. In other words, a new LIST type can be defined wherein only single 

10 errors are listed. Consequently, the size of a resulting S-PDU can be significantly 
reduced for certain error situations, in comparison with the existing LIST solutions. 

Another method that can be used to reduce the size of S-PDUs, in accordance 
with this embodiment, is to combine an existing LIST method (2 SNs per error group) 
with the above-described single error SN LIST method to create the list message. For 

15 example, the existing LIST method can be improved significantly by introducing the 
following rules for creating the LENGTH field value: 

(1) A zero value means that a single error SN LIST method is applied. A 
second (new) length field is included directly after the original LENGTH field to 
indicate the number of single erroneous SNs that follow directly after the second field. 

20 All list elements represent single erroneous SNs, and no acknowledgment is provided 
while using this list method. 

(2) An odd value implies that the last list element is an acknowledgment. 

(3) An even value (excluding zero) implies that the last element is not an 
acknowledgment. 

25 Consequently, following the above-described rules in accordance with this 
embodiment, the (LIST) S-PDU for row 2 in Table 1 now contains the fields and 
contents shown in FIGURE 5. As such, if the field sizes shown in row 2 of the 
example illustrated by Table 1 were to be used with respect to the embodiment 
illustrated by FIGURE 5, then the total size of the S-PDU would be 59 bits. 

3 0 Consequently, in accordance with the present invention, the number of bits needed for 
the resulting S-PDU is significantly smaller than the number of bits (1 14) needed for 
the existing LIST solution. 
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FIGURE 6 is a diagram that illustrates another method that can be used to 
reduce the size of an S-PDU using a LIST method. The method used in accordance 
with this embodiment is to include a field after each list element which determines the 
length of the error, instead of indicating the length of the error with an "ending" SN. 

5 In most systems, the size of the length field would then be substantially smaller than 
the size of the SN field. Furthermore, typically there is no need to represent very large 
consecutive, erroneous D-PDUs (i.e., a large error group) in an S-PDU. 

Referring to FIGURE 6, the fields of a new message (denoted as LIST') in an 
S-PDU are shown. The new length field introduced after each SNj is denoted Lj for 

0 1 s IsLENGTH. Notably, a value of zero can be used for L { to further improve the 
functionality of the resulting LIST' message. As such, the following alternatives can 
be used: 

(1) A zero value for Li means that SNj is an acknowledgment (i.e., Li is not 
pointing out an error). 

5 (2) A zero value represents the end of the LIST' message. The first LENGTH 

field can be omitted if the interpretation of the last SN has been predefined. For 
example, the last SN can be restricted so as to always be an acknowledgment (e.g., as 
in the first alternative), or the length can be predefined (e.g., so as to point out a single 
error). 

0 In accordance with a second embodiment of the present invention, a number 

of different message types can be combined to create an S-PDU. These message types 
can be added in any arbitrary order in the S-PDU, and there is no rule on the number 
of messages or the type of message that can be included in the S-PDU. For this 
exemplary embodiment, each such message includes a type identifier, and the length 

5 is either fixed or indicated by a length field for each specific message. The first type 
identifier preferably has a predefined position in the resulting S-PDU. The rest of the 
type identifiers can be located at arbitrary locations depending on the sizes of the 
included messages. For example, the messages, LIST', BITMAP' and ACK can be 
included in the S-PDU. 

0 The number of such messages that can possibly be included in an S-PDU 

determines the size (bits) of the type identifier field used in the S-PDU. For example, 
the size of such a type identifier field can be determined by the following expression: 
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Size(type.field) 4log 2 (number of possible messages + 1 )i ( 3 ) 



where the operator L J rounds the argument off to the next highest integer value. The 
"+1 " part of the argument is used so that a type identifier can be used to indicate that 
no other messages are included in an S-PDU. This special identifier is denoted herein 
as a "NO_MORE n message. As such, in accordance with Equation (3), the size of the 
5 type field is 2 bits for three different messages, because llog 2 (4)]=2. 

The contents of an "ACK" message constructed in accordance with this 
embodiment are shown in FIGURE 7. The ACK message shown includes a type 
identifier field and SN. This ACK message marks the end of an S-PDU, and all prior 
D-PDUs not indicated to be erroneous within this S-PDU are acknowledged by the 

1 0 SN. Consequently, when such an ACK message is included in an S-PDU, there is no 
need to include a NO_MORE message to terminate the combined S-PDU. 

Assume that a LIST' message with an acknowledgment feature (i.e., a zero 
value for L { means that SNj is an acknowledgment) is used (with a LENGTH field). 
When a BITMAP' message is included directly after a LIST' message, the size of the 

15 FSN field is zero. As such, the first SN which is represented in the bitmap is 
SNlemgto+Llengxh. Furthermore, a zero in the LENGTH field of the LIST' message 
means that an additional LENGTH field is included, and the message is constructed 
as shown in FIGURE 5 with no L^ fields. 

Another way to obtain the above-described LIST feature is to define a new 

20 type (denoted, for example, "LIST"). However, the size of the type field can be 
affected, which can result in a larger S-PDU. In any event, there is a trade-off (which 
is system dependent) to consider in selecting the exact rules to follow for the 
combination method described above. 

FIGURE 8 is a diagram that illustrates how an S-PDU can be constructed in 

25 accordance with the combination method described above. As shown, the resulting 
S-PDU includes two BITMAP' messages and one LIST' message. The second 
BITMAP' message does not include an FSN field (or, the size of the FSN field is 
zero). Consequently, the first element in the bitmap represents the SN having the 
value, SNungth+Lijngth- 
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In order to demonstrate the advantages of the above-described combination 
method, it can be applied to the example described above with respect to Table 1 . As 
such, Table 2 shows different messages (along with their corresponding bit values) 
which can be combined in an S-PDU, in accordance with the second embodiment of 
5 the present invention. For this embodiment, each S-PDU starts with one of the type 
identifiers shown. Also, the sizes of the LENGTH and L^ fields are fixed to 5 bits. 
Consequently, these fields can each hold a value between 0-32(2 5 ). Notably, although 
the sizes of the fields are fixed, their sizes are not necessarily equal, as in this example 
(i.e., the size of the LENGTH field in the BITMAP' message can be different than the 
1 0 size of the LENGTH field in the LIST' message). The value ofthe LENGTH field in 
the BITMAP' message corresponds to the size of the bitmap in bytes (i.e., a maximum 
of 8*32=256 SNs can be addressed in a single S-PDU). All ofthe fields containing 
an SN value have a size of 12 bits (i.e., the FSN, SN and SSN fields). 



Type Identifier 


Value 


NO MORE 


00 


LIST 


01 


BITMAP 


10 


ACK 


11 



Table 2 



2 o FIGURES 9-13, respectively, are diagrams that show the contents of an S-PDU 

for each row shown in Table 1 for the above-described example. For this embodiment, 
the combination is selected so as to minimize the total size ofthe S-PDU. 

As illustrated by the example described above with respect to Table 1, 
FIGURE 9 shows the contents of row 1 in the resulting (combination) S-PDU, 

2 5 FIGURE 1 0 shows the contents of row 2, and FIGURE 1 1 shows the contents of row 
3 . Note that by including an ACK type instead of the list element SNj in FIGURE 1 1 , 
an additional 5 bits can be saved with respect to the total size ofthe S-PDU. FIGURE 
12 shows the contents of row 4 in the resulting S-PDU, and FIGURE 13 shows the 
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contents of row 5. As such, the contents of the entire coded S-PDU can be obtained 
by concatenating all values from the "bits" column. For example, the contents of row 
1 of the S-PDU (FIGURE 9) would appear as: 

,, 01000010000001100111101111000001100101 M . 
5 Table 3 shows the sizes of the S-PDUs constructed in accordance with the 

existing LIST and BITMAP methods, and also the combination method described 
above in accordance with the second embodiment. The sizes of the S-PDUs are 
calculated by adding the "Field size" columns in FIGURES 9-13. As illustrated by 
Table 3, the size of the S-PDU resulting from (he combination method of the present 
10 invention is significantly smaller than the S-PDUs resulting from the existing 
solutions. 





Size of S-PDU 
(bits) 


St9tft.nf.thft.arf solutions 


Combination 
solution 


LIST 


BITMAP 


1 


42 


141 


38 


2 


114 


141 


74 


3 


138 


141 


78 


4 


282 


141 


121 


5 


114 


141 


53 



Table 3 



In many ARQ protocols, the size of the D-PDUs is predefined and can have a 
limited set of different values. Padding can be used if the amount of user data 
2 0 provided to the sending ARQ entity is smaller than the size of the D-PDU. Padding 
is a technique whereby nonsensical data is used to fill up the remaining empty 
locations in the D-PDU. For example, if a D-PDU can be filled with 20 bytes of user 
data, and the sending ARQ entity has only 14 bytes of user data, the rest of the D-PDU 
can be filled or padded with 6 bytes of padding data. The length of the user data part 
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is indicated in the D-PDU. The RLC protocol in the GPRS and W-CDMA systems 

use this type of padding function. 

The combination method of the second embodiment can also be used 

efficiently with piggybacking. For example, an ARQ entity can piggyback status 
5 information after the end of the last user data byte, if enough space exists to fill the 

padding fields with a status message. A NOJMORE type identifier is used whenever 

there is no status information to be included in a D-PDU which contains padding 

bytes. This piggybacking scheme advantageously reduces the number of packets 

being exchanged between two ARQ entities and, consequently, saves system capacity. 
1 0 The cost for such a piggybacking scheme is relatively low, because no field is reserved 

in the D-PDU for the piggybacking scheme, which is the case for existing ARQ 

protocols that use piggybacking. 

Although embodiments of the method and apparatus of the present invention 

have been illustrated in the accompanying Drawings and described in the foregoing 
15 Detailed Description, it will be understood that the invention is not limited to the 

embodiments disclosed, but is capable of numerous rearrangements, modifications and 

substitutions without departing from the spirit of the invention as set forth and defined 

by the following claims. 
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WHATIS CLAIMED IS: 

1. A method for minimizing feedback responses in an ARQ protocol, 
comprising the steps of: 

sending a plurality of first data units over a communication link; 
receiving said plurality of first data units; and 

responsive to the receiving step, constructing amessage field for a second data 
unit, said message field including at least one of a type identifier field, a sequence 
number field, a length field, and a content field. 

2. Themethodof Claim 1, wherein said message field comprises abitmap 
message. 

3. The method of Claim 1, wherein said sequence number field includes 
a sequence number indicating an erroneous first data unit from said plurality of first 
data units. 

4. The method of Claim 1, wherein said sequence number field includes 
any sequence number from said plurality of first data units. 

5. The method of Claim 1 , wherein said length field comprises a length 
value for said content field. 

6. The method of Claim 1, wherein said content field comprises abitmap. 

7. The method of Claim 1, wherein said plurality of first data units 
comprises a plurality of ARQ protocol units including user data. 

8. The method of Claim 1, wherein said second data unit comprises 
information about missing or erroneous said first data units. 
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9. The method of Claim 1 , wherein the size of said length field is zero and 
a predefined bitmap size is used. 

10. The method of Claim 1, wherein said length field indicates a final 
sequence number in a bitmap. 

5 11. The method of Claim 1 , wherein said length field comprises a value of 

zero. 

12. The method of Claim 1, wherein a size of said sequence number field 
equals zero. 

13. The method of Claim 1, wherein at least one of said plurality of first 
10 data units is used to piggy-back said message field. 

14. The method of Claim 1, wherein said ARQ protocol comprises a 
selective-repeat ARQ protocol. 

15. A method for minimizing feedback responses in an ARQ protocol, 
comprising the steps of: 

1 5 sending a plurality of first data units over a communication link; 

receiving said plurality of first data units; and 

responsive to the receiving step, constructing a message field for a second data 
unit, said message field including at least one of a type identifier field, a length field, 
a plurality of erroneous sequence number fields, and a plurality of erroneous sequence 
20 number length fields, each of said plurality of erroneous sequence number fields 
associated with a respective one of said plurality of erroneous sequence number length 
fields. 

16. The method of Claim 15, wherein said message field comprises a list 
message. 
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17. The method of Claim 15, wherein at least one value for said plurality 
of erroneous sequence number length fields comprises zero. 

18. The method of Claim 15, wherein said length field comprises a value 

of zero. 

19. The method of Claim 15, wherein said length field comprises an odd 
value indicating that the last SN is an acknowledgment. 

20. The method of Claim 15, wherein said length field comprises an even 
value indicating that the last SN is not an acknowledgment. 

21. The method of Claim 15, wherein said plurality of first data units 
comprises a plurality of ARQ protocol units including user data. 

22. The method of Claim 15, wherein said second data unit comprises 
information about missing or erroneous said first data units. 

23. The method of Claim 15, wherein at least one of said plurality of first 
data units is used to piggy-back said message field. 

24. The method of Claim 15, wherein said ARQ protocol comprises a 
selective-repeat ARQ protocol. 

25. A method for minimizing feedback responses in an ARQ protocol, 

comprising the steps of: 

sending a plurality of first data units over a communication link; 
receiving said plurality of first data units; and 

responsive to the receiving step, constructing between one to several message 
fields for a second data unit, said one to several message fields including at least one 
of a type identifier field, a sequence number field, a length field, a content field, a 
plurality of erroneous sequence number fields, and a plurality of erroneous sequence 
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number length fields, each of said plurality of erroneous sequence number fields 
associated with a respective one of said plurality of erroneous sequence number length 
fields. 

26. The method of Claim 25, wherein said one to several message fields 
5 further comprise an acknowledgment message. 

27. The method of Claim 25, wherein the last of said one to several 
message fields includes an acknowledgment of all SNs not indicated erroneous by all 
other of said one to several message fields in said second data unit 

28. The method of Claim 25, wherein said one to several message fields 
1 0 further comprise a no more message. 

29. The method of Claim 25, wherein said one to several message fields 
include a bitmap message. 

30. The method of Claim 25, wherein said sequence number field includes 
a sequence number indicating an erroneous first data unit from said plurality of first 

15 data units. 

3 1 . The method of Claim 25, wherein said length field comprises a length 
value for said content field. 

32. The method of Claim 25, wherein said content field comprises a 

bitmap. 

20 33. The method of Claim 25, wherein said plurality of first data units 

comprises a plurality of ARQ protocol units including user data. 

34. The method of Claim 25, wherein said second data unit comprises 
information about missing or erroneous said first data units. 
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35. The method of Claim 25, wherein the size of said length field is zero 
and a predefined bitmap size is used. 

36. The method of Claim 25, wherein said length field indicates a final 
sequence number in a bitmap. 

5 37. The method of Claim 25, wherein said length field comprises a value 

of zero. 

38. The method of Claim 25, wherein a size of said sequence number field 
equals zero. 

39. The method of Claim 25, wherein said one to several message fields 
.0 include a list message. 

40. The method of Claim 25, wherein at least one value for said plurality 
of erroneous sequence number length fields comprises zero. 

41 . The method of Claim 25, wherein said length field comprises an odd 
value indicating that the last SN is an acknowledgment. 

t5 42. The method of Claim 25, wherein said length field comprises an even 

value indicating that the last SN is not an acknowledgment 

43. The method of Claim 25, wherein said ARQ protocol comprises a 
selective-repeat ARQ protocol. 

44. The method of Claim 25, wherein at least one of said plurality of first 
2 0 data units is used to piggy-back said one to several message fields. 



45. A system for minimizing feedback responses in an ARQ protocol, 
comprising: 
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a first peer entity; 

a second peer entity; and 

a communication link coupled between said first peer entity and said second 
peer entity for communicating data therebetween; 
5 said first peer entity including means for sending a plurality of first data units 

over said communication link to said second peer entity; 

said second peer entity including means for receiving said plurality of first data 
units, and constructing one to several message fields for a second data unit, said one 
to several message fields including at least one of a type identifier field, a sequence 
1 0 number field, a length field, a content field, a plurality of erroneous sequence number 
fields, and a plurality of erroneous sequence number length fields, each of said 
plurality of erroneous sequence number fields associated with a respective one of said 
plurality of erroneous sequence number length fields. 

46. The system of Claim 45, wherein said one to several message fields 
15 further comprise an acknowledgment message. 

47. The system of Claim 45, wherein the last of said one to several message 
fields includes an acknowledgment of all SNs not indicated erroneous by all other of 
said one to several message fields in said second data unit. 

48. The system of Claim 45, wherein said one to several message fields 
2 0 further comprise a no more message. 

49. The system of Claim 45, wherein said one to several message fields 
include a bitmap message. 



50. The system of Claim 45, wherein said sequence number field includes 
a sequence number indicating an erroneous first data unit from said plurality of first 
25 data units. 
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51 . The system of Claim 45, wherein said length field comprises a length 
value for said content field. 

52. The system of Claim 45, wherein said content field comprises a bitmap. 

" 53. The system of Claim 45, wherein said plurality of first data units 
5 comprises a plurality of ARQ protocol units including user data 

54. The system of Claim 45, wherein said second data unit comprises 
information about missing or erroneous said first data units. 

55. The system of Claim 45, wherein the size of said length field is zero 
and a predefined bitmap size is used. 

10 56. The system of Claim 45, wherein said length field indicates a final 

sequence number in a bitmap. 

57. The system of Claim 45, wherein said length field comprises a value 

of zero. 

58. The system of Claim 45, wherein a size of said sequence number field 
15 equals zero. 

59. The system of Claim 45, wherein said one to several message fields 
include a list message. 

60. The system of Claim 45, wherein at least one value for said plurality 
of erroneous sequence number length fields comprises zero. 



20 61. The system of Claim 45 , wherein said length field comprises an odd 

value indicating that the last SN is an acknowledgment. 
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62. The system of Claim 45, wherein said length field comprises an even 
value indicating that the last SN is not an acknowledgment. 

63. The system of Claim 45, wherein said ARQ protocol comprises a 
selective-repeat ARQ protocol. 



5 64. The system of Claim 45, wherein at least one of said plurality of first 

data units is used to piggy-back said one to several message fields. 
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FIG. 12 
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